---- start of layout ----
Managing a growing knowledge base in Obsidian can be challenging, especially if you’re new to the app. Many users struggle with organizing their notes in a way that remains efficient and scalable as their vault grows. Fortunately, there’s a powerful and flexible method that can transform how you use Obsidian: combining Maps of Content (MOCs) and Dataview queries.
This method allows your vault to organize itself without constant manual upkeep, making it ideal for anyone looking for a long-term, scalable solution. In this guide, we’ll walk through everything from setting up your first MOC to managing complex subjects, all without needing any prior experience.
A Map of Content, or “MOC”, is like a navigational hub that organizes your notes around a particular topic. Think of it as a dynamic table of contents that lets you quickly access related notes under a single subject area. But there’s more to a MOC than just being a simple list of links—when combined with the Dataview plugin, your MOC becomes a self-updating, dynamic index that grows and evolves with your notes.
At its most basic level, an MOC a note like any other. It is structured with Sections (indicated by # headers
), and each section can have Subsections (## Subtopics
) and even more granular Sub-subsections (### Sub-subtopics
). This hierarchical structure helps you organize your notes in an intuitive way, allowing for both broad overviews and specific details to be linked and categorized.
The main difference is that instead of static content below each # header
, you place a specific Dataview query which monitors your vault on the fly for any notes that might point to that specific # header
in that specific MOC note and is instructed to list them out to you. By doing this, you are instantly updated about any notes that are pointing to that section and in doing so, you have an up to date map of your entire vault.
In traditional note-taking systems, like a file and folder setup, you might create folders within folders to group your notes. For example, if you were organizing notes on philosophy, you might have:
While this folder approach works, it can become restrictive. As you accumulate more notes, or your vault starts to expand beyond its original intent, you may find that a single note belongs to more than one folder, or that certain topics are too broad or narrow to fit neatly into a rigid folder structure.
MOCs provide a flexible alternative to this system. Instead of moving notes into multiple folders or creating complex folder hierarchies, you use MOCs to organize notes by their content and context.
If by chance a MOC needs to be broken up into 2 different MOC’s due to its size, then only the contituent notes need to have their [[MOC Links]]
updated to point to the new broken-out MOC.
The advantage here is that a note can link to multiple MOCs, providing cross-references without having to duplicate the note or move it around manually.
Let’s say you’re building a Philosophy MOC. You could start with an overarching topic like Philosophy and then break it down into several subtopics like Stoicism and Existentialism, which are specific branches within the broader topic.
For example, here’s how your MOC structure might look at the start:
Philosophy MOC (this is the title of the note)
## Stoicism
## Existentialism
You can further break down each subtopic into sub-subtopics (i.e., more detailed areas within Stoicism or Existentialism). For example, under Stoicism, you might want to include prominent Stoic figures like Marcus Aurelius or core concepts like Virtue.
Expanding on the example:
Philosophy MOC (this is the title of the note)
## Stoicism
### Marcus Aurelius
### Virtue
## Existentialism
### Jean-Paul Sartre
### Albert Camus
#### Sisyphus
### Authenticity
EACH of these ## Sections
or #### Sub-Sections
in the MOC would contain their own specific Dataview queries that automatically pull in any & all notes that link out to that specific subtopic or sub-subtopic.
A key feature that makes MOCs so powerful is their ability to remain dynamic (meaning that they update automatically, on their own) with the help of the Dataview plugin. Instead of manually updating your MOCs every time you create or modify a note, Dataview queries constantly get auto-updated as you add, modify or remove notes in your vault. The crafted Dataview queries will automatically pull in notes that reference a specific section of the MOC.
For example, if you create a new note about Marcus Aurelius, and in that note you include a link in the note to the [[Philosophy MOC#Stoicism]]
section, the note will automatically show up under the Stoicism section of your MOC, without you having to do anything else, no editing of the MOC is required, only a new note pointing to that section that the Dataview query is scanning for.
This turns your MOC into a self-updating, living document.
In practice, Dataview queries might look something like this for just the ## Stoicism
section:
Philosophy MOC (this is the note title)
## Stoicism
```dataview
list from ""
where contains(file.outlinks, [[Philosophy MOC#Stoicism]])
sort file.mtime desc
… for the Marcus Aurelius section
Philosophy MOC (this is the note title)
## Marcus Aurelius
```dataview
list from ""
where contains(file.outlinks, [[Philosophy MOC#Marcus Aurelius]])
sort file.mtime desc
… for the Existentialism section
Philosophy MOC (this is the note title)
## Existentialism
```dataview
list from ""
where contains(file.outlinks, [[Philosophy MOC#Existentialism]])
sort file.mtime desc
In this setup:
Because MOCs aren’t restricted by a rigid folder structure, they allow your vault to grow as much as needed, while still keeping everything organized. It’s the MOC’s themselves that get new ## Sub-Sections
if your vault needs to expand, rather than creating static new sub-folders in a rigid structure.
You can create as many subtopics and sub-subtopics as you need, and because each note can link to multiple MOCs, you won’t ever lose track of where a note belongs.
Example: If you have a note titled “Marcus Aurelius - Meditations,” this note can easily link to both the Stoicism and Philosophy MOCs, ensuring it shows up in both places without duplication. Likewise, if your note discusses Virtue as a core Stoic concept, you can link it to both [[Stoicism#Virtue]]
and [[Philosophy MOC]]
all from within the same note, since they’re just links.
MOCs are more flexible than traditional folders because they allow notes to be organized by content rather than by arbitrary file hierarchies.
Using # Sections, ## Subtopics, and ### Sub-subtopics, you can create a detailed and intuitive structure to organize notes by specific topics and their subcategories.
When combined with Dataview, MOCs automatically update themselves, meaning you never need to manually add or rearrange notes within your MOCs as your vault grows.
MOCs also allow for cross-referencing, meaning the same note can appear in multiple MOCs, without the need to copy or duplicate the note.
MOCs give you the freedom to organize your notes in a way that reflects the content and context of your information, while remaining scalable and dynamic as your vault expands.
Before diving into MOCs and Dataview, let’s start with your vault’s overall structure. A simple, minimalist 3-folder structure is all you need:
With this structure, there’s no need to constantly reorganize notes into new folders as your vault grows. Everything will be automatically managed through MOCs and Dataview, which we’ll explain step-by-step.
Let’s start by creating a basic MOC to see how it works.
Philosophy MOC
. This will be the filename for the note, which is key to making sure everything stays linked and accessible.### Sub-sections
. Your MOC should include enough sections and sub-sections to cover a topic sufficiently. You can always add more later. For example, if your MOC is about philosophy, you might include sections like “Stoicism,” “Existentialism,” and “Ethics.”Here’s what the structure might look like:
Philosophy MOC (this is the note title)
## Stoicism
## Existentialism
## Ethics
Each # Section
or ## Subsection
serves as a “container” for its associated Dataview query for notes that will be pointing to that section. As your vault grows, these sections will populate automatically with relevant notes, thanks to the Dataview plugin.
The Dataview plugin allows you to create dynamic lists that update in real-time as you add, modify, or remove notes. Instead of manually updating your MOCs, Dataview automatically pulls in any note that links to a specific section in your MOC.
Now let’s see how Dataview turns your MOC into a dynamic content hub. Under each section header, you’ll add a Dataview query to pull in related notes. For example, to automatically display notes related to Stoicism, you can use this query:
Philosophy MOC (this is the note title)
## Stoicism (this is your plaintext section header)
```dataview
list from ""
where contains(file.outlinks, [[Philosophy MOC#Stoicism]])
sort file.mtime desc
This query tells Dataview to:
[[Philosophy MOC#Stoicism]]
section.The result will be a list of notes related to Stoicism, which will appear under the ## Stoicism
section of your MOC. Each time you create or update a note that links to Stoicism, this list will update automatically.
Repeat this process for the other sections, such as Existentialism and Ethics, by changing the query to match each section name. For example:
Philosophy MOC (this is the note title)
## Existentialism (this is your plaintext section header)
```dataview
list from ""
where contains(file.outlinks, [[Philosophy MOC#Existentialism]])
sort file.mtime desc
Now, your MOC will dynamically pull in and display all relevant notes.
In order for your notes to appear under the correct section in your MOC, you need to make sure that they link back to that section. This can be done easily by following a consistent note template.
Each of your notes should include a link back to the relevant section of the MOC at the top. Here’s a template that you can use to ensure every note is connected to the right MOC:
#### **MapOfContent:** [[Philosophy MOC#Stoicism]] - [[Optional#Second-MOC-Link]] - [[More MOC Links as needed]]
---
Your note content goes here.
---
# References
- [[Link to relevant sources]]
By including the link [[Philosophy MOC#Stoicism]]
in the MapOfContent
field, you ensure that the note is categorized under the Stoicism section in your MOC.
The Dataview query will pick up this link and display the note in the MOC automatically. Other Dataview queries would pick up on the secondary or 3rd MOC links (if you created them) accordingly.
As your vault grows, certain MOCs may become too large to manage in a single page and grow to be very long. When this happens, you can break out specific sections into their own dedicated MOCs. This ensures that your system remains scalable and organized, even as your vault expands.
Over time, as your vault grows, certain sections within a broader MOC can accumulate too many notes to be efficiently managed. When this happens, it’s often necessary to “promote” these sections into their own dedicated MOCs to maintain scalability and organization. This process involves not just creating a new MOC, but also modifying links within the individual notes so that they point to the new MOC.
Let’s walk through this process step-by-step using the Technology MOC example, which includes sections like Coding, Linux, and Software Development.
As you add more notes to your vault, you might find that certain sections within a broader MOC, such as “Coding” within a Technology MOC, begin to feel too crowded. Maybe the number of individual notes about different programming languages or projects is growing, making it harder to navigate and maintain the original MOC.
This is the moment to consider scaling out the section into a standalone MOC.
Once you’ve decided to split the topic into its own MOC, create a new note to serve as the dedicated MOC for that topic. For example, if the “Coding” section is becoming too large, you can create a new note called Coding MOC.
Here’s how the structure of your new Coding MOC might look:
Coding MOC (this is the note title)
## Python
## Bash
## JavaScript
This new MOC will contain the same subtopics that were originally in the Technology MOC, but now they are organized in a separate, dedicated space.
Specific Dataview queries for each of these will go under each “## Section`.
Next, transfer the subsections related to coding from the Technology MOC to the newly created Coding MOC. If you previously had this in the Technology MOC:
# Technology MOC
## Coding
### Python
### Bash
### JavaScript
You’ll move these sections into the new Coding MOC. After this step, your Technology MOC will no longer include the coding sections, but the new Coding MOC will.
Once you’ve moved the sections to the new MOC, it’s time to update the Dataview queries in that will now populate in the new MOCs to ensure that notes continue to be dynamically linked and displayed in the correct MOCs.
Add Dataview queries to the Coding MOC that pull in notes for each subsection (e.g., Python, Bash, JavaScript). For example, under “Python,” you’d use:
list from ""
where contains(file.outlinks, [[Coding MOC#Python]])
sort file.mtime desc
This ensures that all your Python-related notes are displayed under the “Python” subsection of the Coding MOC. You’ll repeat this process for the other subtopics like Bash and JavaScript.
Here’s a critical step that ensures your MOC structure remains effective and functional: updating the individual notes themselves.
When you promote a section into its own MOC, all the notes that previously linked to the old section in the Technology MOC (e.g., [[Technology MOC#Coding]]
) must now be updated to point to the appropriate section in the Coding MOC.
This will be the only labor-intensive part required if you have a lot of notes you’re trying to break off to point to a new MOC.
Go into each note that was linked to the original Technology MOC#Coding section and modify the MapOfContent links to point to the new MOC. For example, if you had a note about Python that was previously linked like this:
#### **MapOfContent:** [[Technology MOC#Coding]]
You will need to update it to:
#### **MapOfContent:** [[Coding MOC#Python]]
This ensures that the note is now properly categorized under the Coding MOC and is pulled into the relevant section of that MOC by the Dataview queries.
You could also of course write a Python script (if you have such skills) do to this for all notes in your vault in 1 shot, if you so choose.
This process of promoting sections into their own MOCs can be repeated as needed. For example, if the Linux section within your Technology MOC eventually becomes too large, you can follow the same steps to create a Linux MOC.
Each time you promote a section into its own MOC, it’s important to:
# sections
from the original MOC to the new MOC.This ensures that your MOCs remain clean, scalable, and interconnected.
The reason it’s so important to update the links in the individual notes is because MOCs work by dynamically pulling in notes based on those links. If a note still points to [[Technology MOC#Coding]]
, but the coding section has been moved to the Coding MOC, that note will no longer appear in the correct place. By taking the time to update each note’s link, you ensure that it remains correctly categorized and displayed.
Additionally, this approach modularizes your vault, so no single MOC becomes too large or difficult to manage. By scaling out sections into their own MOCs, you keep everything organized without sacrificing the ability to easily find and cross-reference your notes.
Coding MOC
).Technology MOC
) to the new MOC.[[Coding MOC#Python]]
instead of [[Technology MOC#Coding]]
).This method allows you to seamlessly grow your vault, while keeping everything organized, interconnected, and accessible.
One of the main advantages of this system is its scalability. Unlike traditional folder structures, which require manual reorganization as your notes grow, MOCs and Dataview queries adapt automatically. Here are a few key reasons why this system works so well:
Combining Maps of Content (MOCs) with the Dataview plugin transforms your Obsidian vault into a self-organizing knowledge hub. What makes this approach so powerful is its flexibility and scalability, allowing you to manage your vault efficiently—whether it contains a handful of notes or thousands of them. Let’s delve deeper into why this method is better, less work-intensive, and more efficient compared to other popular approaches for note management.
One of the standout advantages of using MOCs with Dataview is the minimal manual intervention required. In traditional folder-based systems, or even systems relying heavily on manual tags and links, you have to continually update the structure. Every time you create or modify a note, there’s an expectation to:
In contrast, the MOC + Dataview system automates much of this overhead. With a single link to an MOC section (e.g., [[Philosophy MOC#Stoicism]]
), your notes are dynamically categorized and displayed. Once the Dataview queries are in place, they automatically pull in and update notes, saving you from having to manually organize your notes into folders or manually curate index pages. This eliminates the constant reorganization that comes with other methods, allowing you to focus on content creation rather than content management.
In systems that rely on rigid folder structures, as your vault grows, so does the complexity of your folders. Over time, you find yourself endlessly creating new subfolders, trying to fit notes into categories. This phenomenon is often referred to as “folder creep,” where the number of folders becomes unmanageable, and finding the right folder for a note becomes more cumbersome than productive.
With the MOC + Dataview system, there is no need to create endless folders. MOCs grow and evolve with your vault, allowing you to dynamically organize content by context and subject matter, not by arbitrary file location. When a section within a MOC becomes too large (e.g., Coding in a Technology MOC), you simply promote it into its own MOC, as we discussed earlier, without changing the underlying structure of your vault.
By eliminating the need for constant folder restructuring, you reduce friction in your workflow, making it easier to find and reference notes regardless of how large your vault becomes.
Another key advantage of the MOC system is flexibility. In a traditional folder system, each note can only exist in one folder, which often limits how you can organize your information. For example, a note on Marcus Aurelius could fit under both Philosophy and Stoicism, but in a folder system, you’d have to choose just one location or create duplicate notes.
With MOCs, however, notes can easily belong to multiple MOCs without duplication. A note about Marcus Aurelius - Meditations can be linked to both [[Philosophy MOC#Stoicism]]
and [[History MOC#Roman Empire]]
, ensuring it appears under both subjects. This kind of cross-linking allows you to organize information according to its content and relevance to multiple subjects, without the limitations imposed by folders.
This flexibility also extends to the way you can reuse and reorganize information. If you start with a broad MOC and later find that certain sections grow too large, you can break them out into their own MOCs—promoting them as needed—without disrupting the underlying structure of your notes.
When comparing the MOC + Dataview approach to other popular methods, such as heavy reliance on tags, folders, or manually curated indexes, the MOC system is far more efficient for several reasons:
Tags Require Maintenance: Systems based on tags often become cluttered and redundant. You must create and maintain a taxonomy of tags, which requires constant upkeep.
Tags are useful for quick categorization (usually for a transient status of a note, such as “Pending”), but they don’t provide the structured context that MOCs do, and they require manual intervention to create and curate.
Moreover, tags don’t have the same cross-referencing power that MOCs provide when you use them in combination with Dataview queries.
Folders Are Rigid: Folder-based systems can quickly become overwhelming as the number of notes grows. Once a note is placed in a folder, it’s not easy to make that same note accessible under different contexts, which can lead to a need for duplicated notes or complex, deep folder structures. With MOCs, you eliminate this rigidity. Notes can be linked to multiple MOCs without duplication, and MOCs themselves can evolve as your vault grows.
Manual Indexes Are Time-Consuming: Systems that rely on manually created MOC’s with static page links, where one has to manually update and curate every link in every MOC after any note is added or modified becomes a labor-intensive chore.
With Dataview, this process is completely automated—your MOCs update themselves every time a note is added, modified, or removed.
Ultimately, the MOC + Dataview approach reduces the cognitive load and the time spent managing your vault, making it a much more hands-off, automated, and efficient system compared to other methods.
One of the most powerful aspects of this system is that it can grow with you. For beginners, starting with a few MOCs and simple Dataview queries is a straightforward way to begin organizing your notes. As your vault grows, you can introduce more complex structures, like:
## Subtopics
and ### Sub-subtopics
to further organize your content.This adaptability allows the system to remain useful whether you have 10 notes or 10,000 notes. You’re never locked into a rigid system—you can evolve your MOCs as your knowledge expands, always maintaining an organized and connected vault.
By combining MOCs with Dataview, you create a living, dynamic structure that organizes itself around your notes. This method eliminates the need for constant upkeep, allows for flexible organization, and scales effortlessly as your vault grows. Whether you’re managing a few notes for personal research or an extensive knowledge base, this system adapts to your needs, evolving alongside your growing vault.
Invest the time to experiment with this structure, and you’ll quickly see how it can transform the way you manage and interact with your notes—offering a far more streamlined, flexible, and efficient approach than other methods.
Hope this helps!
The present holds infinite possibilities.
---- End of layout ----